草庐IT

C++ std::thread

全部标签

multithreading - 戈朗 : how to bind code with thread?

我几乎实现了人脸识别围棋服务器。我的人脸识别算法使用caffe,caffe是一个线程绑定(bind)图形库,这意味着我必须在同一个线程中初始化和调用算法,所以我检查了LockOSThread().LockOSThread使用1个线程,但我的服务器拥有4个GPU。在C/C++中,我可以创建4个线程,在每个线程中初始化算法,使用sem_wait和sem_post分配任务,1线程使用1个GPU。如何在Go中做同样的事情,如何将代码与线程绑定(bind)? 最佳答案 您生成了一些goroutines,在每个goroutines中运行runt

go - 有什么方法可以使用 golang std 库来格式化日志(如下所述)?

2018年2月1日下午3:04:05(UTC)|这是日志消息2018-02-01T15:04:05Z|这是日志消息我在gosrc中找到了下一个格式:https://github.com/golang/go/blob/master/src/log/log.go#L37但似乎我无法仅使用那些来做到这一点.. 最佳答案 这里有两个选项:使用log.SetOutput设置自定义编写器。或者使用fmt包而不是只打印到stdout或其他地方-stdlib日志包做的不多而且很容易创建你自己的日志包,它以自定义时间格式输出到stdout(或日志文件

multithreading - 如何在go中转换以下Thread语句

我正在尝试在go中转换以下线程的java语句;intnum=5;Thread[]threads=newThread[5];for(inti=0;i我想知道,如何将其转换为go?谢谢 最佳答案 Golang使用了一个叫做"goroutines"的概念(灵感来自"coroutines")而不是许多其他语言使用的“线程”。您的具体示例看起来像是sync.WaitGroup的常见用法输入:wg:=sync.WaitGroup{}fori:=0;i请注意,示例中的SomeFunction(...)可以是任何类型的工作,并将与所有其他调用同时执

time - 戈朗 : throttle (time delay) function is not working in goroutine (works fine in main thread)

所以我正在编写一个实用程序来查询工作中的API,它们将每10秒限制为20次调用。很简单,我会将我的通话时间限制在自上次通话后至少0.5秒。在我尝试使用goroutine之前,我的Throttle实用程序运行良好。现在我正在使用结构/方法组合:func(c*CTKAPI)Throttle(){ifc.Debug{fmt.Println("\t\t\tEnteringThrottle()")}for{//incasesomethingelsemakesacallwhilewe'resleeping,weneedtore-checkift:=time.Now().Sub(c.LastCall

concurrency - 如何将多个 goroutine 同步到所选 goroutine 的终止(即 Thread.join())

我在上一个问题中问过这个问题,但有些人觉得我最初的问题不够详细(“为什么你会想要一个定时条件等待??”)所以这里有一个更具体的问题。我有一个goroutine正在运行,称之为服务器。它已经启动,将执行一段时间,然后执行它的操作。然后,它将退出,因为它已完成。在它执行期间,一些大量的其他goroutines开始。如果您愿意,可以将它们称为“客户端”线程。他们运行步骤A和步骤B。然后,他们必须等待“服务器”goroutine完成一段指定的时间,如果“服务器未完成”则以状态退出,如果完成则运行步骤C。(请不要告诉我如何重构此工作流。这是假设的,是给定的。无法更改。)一个正常、明智的方法是让服

golang 运行时 : failed to create new OS thread (have 2049 already; errno=12)

我在MacOs上创建了很多goroutine,程序执行时出现错误。goRoutineId=3710,i=3683,len(chan)=2049runtime:failedtocreatenewOSthread(have2049already;errno=12)fatalerror:runtime.newosproc所以我想知道“无法创建新的OS线程”是什么意思,这是操作系统的限制,只是golang没有能力创建更多的goroutine?谢谢你帮助我。 最佳答案 这是操作系统的限制。我假设您使用的是Linux。根据thesourceof

xml - 如何使用 xml golang std 查找已知属性和 token 的值。库

我正在解析这样设置的http请求的主体:...............查找VALUE_I_WANT的惯用方法是什么?我可以使用解码器遍历token吗?如何检查token是否为foo并获取属性bar?(这些名字是不变的)。这是使用标准库的唯一方法吗?没办法直接查token? 最佳答案 您可以使用encoding/xml包来解析您的数据。例如,定义表示XML数据的类型:typeSomethingstruct{InnerSomethingstruct{Foostruct{Barstring`xml:"bar,attr"`}`xml:"fo

C++/STL - 在 std::map 中访问类指针实例时程序崩溃

好的,我有一个函数可以读取xml文件并使用new创建控件并将它们存储在名为Window的类的公共(public)成员变量中:std::mapButtons;std::mapTextBoxes;std::mapCheckBoxes;Button、TextBox和CheckBox类是CreateWindowEx的自制包装器。这是填充map的函数:voidWindow::LoadFromXml(constchar*fileName){XMLNoderoot=XMLNode::openFileHelper(fileName,"Window");for(inti=0;i(root.getChil

c++ - std::vector 的异常行为

我编写了一组相当复杂的类来处理流(字符串、文件或内存)的迭代。这些不是标准流,也不相关。无论如何,由于遍历这些缓冲区并根据缓冲区执行操作,我希望能够在调试器中看到当前缓冲区位置。因此,仅出于调试原因,我将整个流复制到一个vector,并保存指向该vector中某个位置的指针。下面的代码就像一个前向迭代器。我需要能够存储一个位置,然后使用它或更新它。请注意,此代码只是为了复制问题。classfoo{public:foo(std::stringszTemp):nOffset(0){vec.resize(szTemp.size());std::memcpy(&vec[0],szTemp.c_

c# - (来自 HRESULT : 0x8001010E (RPC_E_WRONG_THREAD)) 的异常

我尝试将ObservableCollection关联到ListBox,但出现以下错误:应用程序调用了一个为不同线程编码的接口(interface)。(HRESULT异常:0x8001010E(RPC_E_WRONG_THREAD))Prueba.cs在类里面,我有:publicObservableCollectionWidgetsDownloaded(stringe){intalertas=0;XDocumentdocument=XDocument.Parse(e);//Obtenerelid//id=document.Root.Element("id").Value;Observab